import vnode from "./vnode";
import createElement from "./createElement";
import patchVNode from "./patchVNode";

export default function patch(oldVnode, newVnode) {
    // 判断传入的第一个参数，是DOM节点还是虚拟节点
    if (oldVnode.sel == '' || oldVnode.sel == undefined) {
        // 如果是DOM节点，此时要包装为虚拟节点
        oldVnode = vnode(oldVnode.tagName.toLowerCase(), {}, [], undefined, oldVnode)
    }

    // 判断oldVnode和newVnode是不是同一个节点
    if (oldVnode.key == newVnode.key && oldVnode.sel == newVnode.sel) {
        // 是同一节点
        patchVNode(oldVnode,newVnode)
    } else {
        // 不是同一个节点，删除旧节点，插入新节点
        let newVnodeElm = createElement(newVnode);
        // 插入到旧节点之前
        if (oldVnode.elm.parentNode && newVnodeElm){
            oldVnode.elm.parentNode.insertBefore(newVnodeElm, oldVnode.elm);
        }
        oldVnode.elm.parentNode.removeChild(oldVnode.elm)
    }
}
